/*
 * Copyright 2025 The JA-SIG Collaborative. All rights reserved.
 * distributed with this file and available online at
 */
package com.lap.auth.adapter.driven.web.job;

import com.lap.auth.application.job.JobAppService;
import com.lap.auth.application.job.command.CreateJobCmd;
import com.lap.auth.application.job.command.UpdateJobCmd;
import com.lap.auth.application.job.dto.JobDto;
import com.lap.auth.application.job.dto.QueryJobPageQuery;
import com.lap.framework.annotation.NotAuth;
import com.lap.framework.dto.page.PageResponse;
import com.lap.watchdog.starter.annotation.RepeatSubmit;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import jakarta.validation.Valid;
import lombok.RequiredArgsConstructor;
import org.springframework.web.bind.annotation.*;

/**
 * 提供岗位restful接口层:
 *
 * <ol>
 *   <li>业务规则，原则上不做任何业务逻辑处理，仅仅是技术入口
 *   <li>命名规则，语义上明确接口做什么，推荐使用 Restful 命名 + Verb风格方法名（适配Swagger、Spring）:
 *       <ul>
 *         <li>分页使用 getXXXPage
 *         <li>获取单个 getXXById
 *         <li>保存使用 createXX
 *         <li>更新使用 updateXX
 *         <li>删除使用 deleteXX
 *       </ul>
 * </ol>
 *
 * @author Shuisheng Lao(劳水生)
 * @version 0.0.1
 */
@Tag(name = "岗位管理", description = "提供岗位基本操作，查询等")
@RequiredArgsConstructor
@RestController
@RequestMapping("api/v1/jobs")
public class JobController {

  private final JobAppService jobAppService;

  @Operation(summary = "获取岗位")
  @NotAuth
  @GetMapping
  public PageResponse<JobDto> getJobPage(QueryJobPageQuery query) {
    return jobAppService.queryJobsByPage(query);
  }

  @Operation(summary = "添加岗位")
  @RepeatSubmit
  @PostMapping
  public Integer createJob(@RequestBody @Valid CreateJobCmd cmd) {
    return jobAppService.createJob(cmd);
  }

  @Operation(summary = "更新岗位")
  @RepeatSubmit
  @PutMapping("{id}")
  public Integer updateJob(@PathVariable Integer id, @RequestBody @Valid UpdateJobCmd cmd) {
    return jobAppService.updateJob(id, cmd);
  }

  @Operation(summary = "删除岗位")
  @RepeatSubmit
  @DeleteMapping("{id}")
  public Integer deleteJob(@PathVariable Integer id) {
    return jobAppService.deleteJob(id);
  }
}
